<template lang="html">
	<div class="ffz--term">
		<div class="tw-align-items-center tw-flex tw-flex-wrap tw-flex-row tw-full-width">
			<div v-if="! is_valid" class="tw-relative ffz-il-tooltip__container tw-mg-r-05">
				<figure class="tw-c-text-error ffz-i-attention" />
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-left">
					{{ t('setting.terms.warn-invalid', 'This highlight term is invalid.') }}
				</div>
			</div>
			<div v-if="! is_safe" class="tw-relative ffz-il-tooltip__container tw-mg-r-05">
				<figure class="tw-c-text-hint ffz-i-attention" />
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-left">
					{{ t('setting.terms.warn-complex', 'This highlight term is potentially too complex. It may cause client lag.') }}
				</div>
			</div>
			<div class="tw-flex-grow-1">
				<h4 v-if="! editing" class="ffz-monospace ffz-font-size-4">
					<pre>{{ term.v }}</pre>
				</h4>
				<input
					v-else
					v-model="edit_data.v"
					:placeholder="adding ? t('setting.terms.add-placeholder', 'Add a new term') : edit_data.v"
					type="text"
					class="tw-block tw-full-width tw-border-radius-medium ffz-font-size-6 tw-full-width ffz-input tw-pd-x-1 tw-pd-y-05"
					autocapitalize="off"
					autocorrect="off"
				>
			</div>
			<div class="tw-flex-shrink-0 tw-mg-x-05">
				<span v-if="! editing">{{ term_type }}</span>
				<select
					v-else
					v-model="edit_data.t"
					class="tw-block tw-border-radius-medium ffz-font-size-6 ffz-select tw-pd-l-1 tw-pd-r-3 tw-pd-y-05 ffz-min-width-unset"
				>
					<option value="text">
						{{ t('setting.terms.type.text', 'Text') }}
					</option>
					<option value="glob">
						{{ t('setting.terms.type.glob', 'Glob') }}
					</option>
					<!--option v-if="words" value="regex">
						{{ t('setting.terms.type.regex-word', 'Regex (Word)') }}
					</option-->
					<option value="raw">
						{{ t('setting.terms.type.regex', 'Regex') }}
					</option>
				</select>
			</div>
			<div v-if="colored" class="tw-flex-shrink-0 tw-mg-r-05">
				<color-picker
					v-if="editing"
					v-model="edit_data.c"
					:nullable="true"
					:show-input="false"
					:tooltip="t('settings.term.color.tip', 'Color')"
				/>
				<div v-else-if="term.c" class="ffz-color-preview tw-relative ffz-il-tooltip__container">
					<figure :style="`background-color: ${term.c}`">
						&nbsp;
					</figure>
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('settings.term.color.tip', 'Color') }}
					</div>
				</div>
			</div>
			<div
				v-if="priority"
				:class="editing ? 'tw-mg-r-05' : 'tw-mg-x-05'"
				class="tw-flex-shrink-0 tw-relative ffz-il-tooltip__container"
			>
				<span v-if="! editing">{{ term.p }}</span>
				<input
					v-else
					v-model.number="edit_data.p"
					type="number"
					step="1"
					class="tw-block tw-border-radius-medium ffz-font-size-6 ffz-min-width-unset ffz-input tw-pd-x-1 tw-pd-y-05"
					style="width: 5rem"
				>
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
					{{ t('settings.terms.priority.tip', 'Priority') }}
				</div>
			</div>
			<div
				v-if="editing || display.s"
				class="tw-flex-shrink-0 tw-mg-r-05 tw-mg-y-05 tw-flex tw-align-items-center ffz-checkbox tw-relative ffz-il-tooltip__container"
			>
				<input
					v-if="editing"
					:id="'sensitive$' + id"
					v-model="edit_data.s"
					type="checkbox"
					class="ffz-min-width-unset ffz-checkbox__input"
				>
				<label
					v-if="editing"
					:for="'sensitive$' + id"
					class="ffz-min-width-unset ffz-checkbox__label"
				>
					<span class="tw-mg-l-05">
						{{ t('settings.terms.sensitive', 'Aa') }}
					</span>
				</label>
				<div v-else-if="display.s" class="tw-relative ffz-il-tooltip__container">
					<span class="tw-mg-l-05">
						{{ t('settings.terms.sensitive', 'Aa') }}
					</span>
				</div>
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
					{{ t('settings.terms.sensitive.tip', 'Case Sensitive') }}
				</div>
			</div>
			<div
				v-if="words && (editing || display.w)"
				class="tw-flex-shrink-0 tw-mg-r-05 tw-mg-y-05 tw-flex tw-align-items-center ffz-checkbox tw-relative ffz-il-tooltip__container"
			>
				<input
					v-if="editing"
					:id="'word$' + id"
					v-model="edit_data.w"
					type="checkbox"
					class="ffz-min-width-unset ffz-checkbox__input"
				>
				<label
					v-if="editing"
					:for="'word$' + id"
					class="ffz-min-width-unset ffz-checkbox__label"
				>
					<span class="tw-mg-l-05 ffz--whole-word">
						{{ t('settings.terms.word', 'Abc') }}
					</span>
				</label>
				<div v-else-if="display.w" class="tw-relative ffz-il-tooltip__container">
					<span class="tw-mg-l-05 ffz--whole-word">
						{{ t('settings.terms.word', 'Abc') }}
					</span>
				</div>
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
					{{ t('settings.terms.word.tip', 'Match Whole Words') }}
				</div>
			</div>
			<div
				v-if="highlight && (editing || display.h)"
				class="tw-flex-shrink-0 tw-mg-r-05 tw-mg-y-05 tw-flex tw-align-items-center ffz-checkbox tw-relative ffz-il-tooltip__container"
			>
				<input
					v-if="editing"
					:id="'highlight$' + id"
					v-model="edit_data.h"
					type="checkbox"
					class="ffz-min-width-unset ffz-checkbox__input"
				>
				<label
					v-if="editing"
					:for="'highlight$' + id"
					class="ffz-min-width-unset ffz-checkbox__label"
				>
					<span class="tw-mg-l-05 ffz--highlight">
						{{ t('settings.terms.highlight', 'Hlt') }}
					</span>
				</label>
				<div v-else-if="display.h" class="tw-relative ffz-il-tooltip__container">
					<span class="tw-mg-l-05 ffz--highlight">
						{{ t('settings.terms.highlight', 'Hlt') }}
					</span>
				</div>
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
					<markdown
						:source="t(
							'settings.terms.highlight.tip',
							'Highlight Matches\n\nThis requires the \'Highlight matched words in chat.\' setting to work.'
						)"
					/>
				</div>
			</div>
			<div
				v-if="removable && (editing || display.remove)"
				class="tw-flex-shrink-0 tw-mg-r-05 tw-mg-y-05 tw-flex tw-align-items-center ffz-checkbox tw-relative ffz-il-tooltip__container"
			>
				<input
					v-if="editing"
					:id="'remove$' + id"
					v-model="edit_data.remove"
					type="checkbox"
					class="ffz-min-width-unset ffz-checkbox__input"
				>

				<label
					v-if="editing"
					:for="'remove$' + id"
					class="ffz-min-width-unset ffz-checkbox__label"
				>
					<span class="tw-mg-l-05 ffz-i-trash" />
				</label>
				<span
					v-else-if="term.remove"
					class="ffz-i-trash tw-pd-x-1"
				/>
				<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
					{{ t('setting.terms.remove.on', 'Remove matching messages from chat.') }}
				</div>
			</div>
			<div v-if="adding" class="tw-flex-shrink-0">
				<button class="tw-button" @click="save">
					<span class="tw-button__text">
						{{ t('setting.terms.add-term', 'Add') }}
					</span>
				</button>
			</div>
			<div v-else-if="editing" class="tw-flex-shrink-0">
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="save">
					<span class="tw-button__text ffz-i-floppy" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.save', 'Save') }}
					</div>
				</button>
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="cancel">
					<span class="tw-button__text ffz-i-cancel" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.cancel', 'Cancel') }}
					</div>
				</button>
			</div>
			<div v-else-if="deleting" class="tw-flex-shrink-0">
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="$emit('remove', term)">
					<span class="tw-button__text ffz-i-trash" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.delete', 'Delete') }}
					</div>
				</button>
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="deleting = false">
					<span class="tw-button__text ffz-i-cancel" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.cancel', 'Cancel') }}
					</div>
				</button>
			</div>
			<div v-else class="tw-flex-shrink-0">
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="edit">
					<span class="tw-button__text ffz-i-cog" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.edit', 'Edit') }}
					</div>
				</button>
				<button class="tw-button tw-button--text ffz-il-tooltip__container" @click="deleting = true">
					<span class="tw-button__text ffz-i-trash" />
					<div class="ffz-il-tooltip ffz-il-tooltip--down ffz-il-tooltip--align-right">
						{{ t('setting.delete', 'Delete') }}
					</div>
				</button>
			</div>
		</div>
	</div>
</template>

<script>

import safety from 'safe-regex';

import {deep_copy, glob_to_regex, escape_regex} from 'utilities/object';

let id = 0;

export default {
	props: {
		term: Object,
		highlight: {
			type: Boolean,
			default: false
		},
		priority: {
			type: Boolean,
			default: false
		},
		words: {
			type: Boolean,
			default: true
		},
		colored: {
			type: Boolean,
			default: false
		},
		removable: {
			type: Boolean,
			default: false
		},
		adding: {
			type: Boolean,
			default: false
		}
	},

	data() {
		const this_id = `term$${id++}`;

		if ( this.adding )
			return {
				id: this_id,
				deleting: false,
				editing: true,
				edit_data: deep_copy(this.term)
			};

		return {
			id: this_id,
			deleting: false,
			editing: false,
			edit_data: null
		}
	},

	computed: {
		display() {
			return this.editing ? this.edit_data : this.term;
		},

		is_valid() {
			const data = this.display,
				t = data.t;

			let v = data.v;

			if ( t === 'text' )
				v = escape_regex(v);

			else if ( t === 'glob' )
				v = glob_to_regex(v);

			try {
				new RegExp(v);
				return true;
			} catch(err) {
				return false;
			}
		},

		is_safe() {
			const data = this.display,
				t = data.t;

			let v = data.v;

			if ( t === 'text' )
				v = escape_regex(v);

			else if ( t === 'glob' )
				v = glob_to_regex(v);

			return safety(v);
		},

		term_type() {
			const t = this.term && this.term.t;
			if ( t === 'text' )
				return this.t('setting.terms.type.text', 'Text');

			else if ( t === 'raw' )
				return this.t('setting.terms.type.raw', 'Regex');

			else if ( t === 'glob' )
				return this.t('setting.terms.type.glob', 'Glob');

			else if ( t === 'regex' )
				return this.t('setting.terms.type.regex-word', 'Regex (Word)');

			return this.t('setting.unknown', 'Unknown Value');
		}
	},

	methods: {
		edit() {
			this.editing = true;
			this.edit_data = Object.assign({remove: false}, deep_copy(this.term));
		},

		toggleRemove() {
			if ( this.editing )
				this.edit_data.remove = ! this.edit_data.remove;
		},

		cancel() {
			if ( this.adding ) {
				this.edit_data = deep_copy(this.term);

			} else {
				this.editing = false;
				this.edit_data = null;
			}
		},

		save() {
			if ( this.priority && this.edit_data.p ) {
				if ( typeof this.edit_data.p === 'number' )
					this.edit_data.p = Math.floor(this.edit_data.p);
				else
					this.edit_data.p = 0;
			}

			this.$emit('save', this.edit_data);
			this.cancel();
		}
	}
}

</script>
